From: Jonas Ã…dahl Date: Thu, 28 Jun 2018 09:41:09 +0000 (+0200) Subject: wayland: Update cursor surface scale when output scale changes X-Git-Tag: archive/raspbian/3.24.39-1+rpi1~1^2~65^2~34^2~24^2 X-Git-Url: https://dgit.raspbian.org/%22http://www.example.com/cgi/success/%22http:/www.example.com/cgi/success?a=commitdiff_plain;h=3354d9109062d12890787bc1f1d23ddc1c3ea77a;p=gtk%2B3.0.git wayland: Update cursor surface scale when output scale changes Cursor surfaces didn't listen for output scale changes, meaning they didn't adapt their scale when an output changed scale, which could happen for example when changing the monitor scale via Settings. --- diff --git a/gdk/wayland/gdkdevice-wayland.c b/gdk/wayland/gdkdevice-wayland.c index 807f0a29ff..fb3cfcb505 100644 --- a/gdk/wayland/gdkdevice-wayland.c +++ b/gdk/wayland/gdkdevice-wayland.c @@ -310,6 +310,9 @@ struct _GdkWaylandDeviceManagerClass GdkDeviceManagerClass parent_class; }; +static void +pointer_surface_update_scale (GdkDevice *device); + static void deliver_key_event (GdkWaylandSeat *seat, uint32_t time_, uint32_t key, @@ -4501,10 +4504,18 @@ static const struct zwp_tablet_seat_v2_listener tablet_seat_listener = { tablet_seat_handle_pad_added, }; +static void +on_monitors_changed (GdkScreen *screen, + GdkWaylandSeat *seat) +{ + pointer_surface_update_scale (seat->master_pointer); +} + static void init_devices (GdkWaylandSeat *seat) { GdkWaylandDeviceManager *device_manager = GDK_WAYLAND_DEVICE_MANAGER (seat->device_manager); + GdkWaylandDisplay *display = GDK_WAYLAND_DISPLAY (seat->display); /* pointer */ seat->master_pointer = g_object_new (GDK_TYPE_WAYLAND_DEVICE, @@ -4524,6 +4535,9 @@ init_devices (GdkWaylandSeat *seat) g_list_prepend (device_manager->devices, seat->master_pointer); g_signal_emit_by_name (device_manager, "device-added", seat->master_pointer); + g_signal_connect (display->screen, "monitors-changed", + G_CALLBACK (on_monitors_changed), seat); + /* keyboard */ seat->master_keyboard = g_object_new (GDK_TYPE_WAYLAND_DEVICE, "name", "Core Keyboard",